

PCT

WORLD INTELLECTUAL PROPERTY ORGANIZATION  
International Bureau

## INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT)

|                                                                                                                                                |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| (51) International Patent Classification <sup>6</sup> :<br><br>G06F 9/305                                                                      |  | A1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (11) International Publication Number: <b>WO 99/01814</b><br><br>(43) International Publication Date: 14 January 1999 (14.01.99) |
| (21) International Application Number: PCT/US98/13823                                                                                          |  | (81) Designated States: AL, AM, AT, AU, AZ, BA, BB, BG, BR, BY, CA, CH, CN, CU, CZ, DE, DK, EE, ES, FI, GB, GE, GH, GM, GW, HR, HU, ID, IL, IS, JP, KE, KG, KP, KR, KZ, LC, LK, LR, LS, LT, LU, LV, MD, MG, MK, MN, MW, MX, NO, NZ, PL, PT, RO, RU, SD, SE, SG, SI, SK, SL, TJ, TM, TR, TT, UA, UG, US, UZ, VN, YU, ZW, ARIPO patent (GH, GM, KE, LS, MW, SD, SZ, UG, ZW), Eurasian patent (AM, AZ, BY, KG, KZ, MD, RU, TJ, TM), European patent (AT, BE, CH, CY, DE, DK, ES, FI, FR, GB, GR, IE, IT, LU, MC, NL, PT, SE), OAPI patent (BF, BJ, CF, CG, CI, CM, GA, GN, ML, MR, NE, SN, TD, TG). |                                                                                                                                  |
| (22) International Filing Date: 2 July 1998 (02.07.98)                                                                                         |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| (30) Priority Data:<br>08/886,920 2 July 1997 (02.07.97) US                                                                                    |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| (63) Related by Continuation (CON) or Continuation-in-Part (CIP) to Earlier Application<br>US Filed on 08/886,920 (CON) 2 July 1997 (02.07.97) |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| (71) Applicant (for all designated States except US): CREATIVE TECHNOLOGY, LTD. [SG/SG]; 67 Ayer Rajah Crescent #103-18, Singapore 0513 (SG).  |  | Published<br>With international search report.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                  |
| (72) Inventor; and                                                                                                                             |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| (75) Inventor/Applicant (for US only): HOGE, Stephen [US/US]; 150 Baldwin Street, Santa Cruz, CA 95060 (US).                                   |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| (74) Agents: LANG, Dan, H. et al.; Townsend and Townsend and Crew LLP, 8th floor, Two Embarcadero Center, San Francisco, CA 94111-3834 (US).   |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |

(54) Title: PROCESSOR WITH INSTRUCTION SET FOR AUDIO EFFECTS



(57) Abstract

An instruction set for control of an audio signal processor (200) that allows for a high degree of flexibility in generating desired sound effects. The instruction set serves as a multi-functional instruction base upon which other specialized sound effects can be constructed.

**FOR THE PURPOSES OF INFORMATION ONLY**

Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT.

|    |                          |    |                                       |    |                                           |    |                          |
|----|--------------------------|----|---------------------------------------|----|-------------------------------------------|----|--------------------------|
| AL | Albania                  | ES | Spain                                 | LS | Lesotho                                   | SI | Slovenia                 |
| AM | Armenia                  | FI | Finland                               | LT | Lithuania                                 | SK | Slovakia                 |
| AT | Austria                  | FR | France                                | LU | Luxembourg                                | SN | Senegal                  |
| AU | Australia                | GA | Gabon                                 | LV | Latvia                                    | SZ | Swaziland                |
| AZ | Azerbaijan               | GB | United Kingdom                        | MC | Monaco                                    | TD | Chad                     |
| BA | Bosnia and Herzegovina   | GE | Georgia                               | MD | Republic of Moldova                       | TG | Togo                     |
| BB | Barbados                 | GH | Ghana                                 | MG | Madagascar                                | TJ | Tajikistan               |
| BE | Belgium                  | GN | Guinea                                | MK | The former Yugoslav Republic of Macedonia | TM | Turkmenistan             |
| BF | Burkina Faso             | GR | Greece                                | ML | Mali                                      | TR | Turkey                   |
| BG | Bulgaria                 | HU | Hungary                               | MN | Mongolia                                  | TT | Trinidad and Tobago      |
| BJ | Benin                    | IE | Ireland                               | MR | Mauritania                                | UA | Ukraine                  |
| BR | Brazil                   | IL | Israel                                | MW | Malawi                                    | UG | Uganda                   |
| BY | Belarus                  | IS | Iceland                               | MX | Mexico                                    | US | United States of America |
| CA | Canada                   | IT | Italy                                 | NE | Niger                                     | UZ | Uzbekistan               |
| CF | Central African Republic | JP | Japan                                 | NL | Netherlands                               | VN | Viet Nam                 |
| CG | Congo                    | KE | Kenya                                 | NO | Norway                                    | YU | Yugoslavia               |
| CH | Switzerland              | KG | Kyrgyzstan                            | NZ | New Zealand                               | ZW | Zimbabwe                 |
| CI | Côte d'Ivoire            | KP | Democratic People's Republic of Korea | PL | Poland                                    |    |                          |
| CM | Cameroon                 | KR | Republic of Korea                     | PT | Portugal                                  |    |                          |
| CN | China                    | KZ | Kazakhstan                            | RO | Romania                                   |    |                          |
| CU | Cuba                     | LC | Saint Lucia                           | RU | Russian Federation                        |    |                          |
| CZ | Czech Republic           | LI | Liechtenstein                         | SD | Sudan                                     |    |                          |
| DE | Germany                  | LK | Sri Lanka                             | SE | Sweden                                    |    |                          |
| DK | Denmark                  | LR | Liberia                               | SG | Singapore                                 |    |                          |



Accumulate," as well as logical instructions such as "AND," "OR," and "XOR."

5 While many ASPs make use of the conventional DSP instructions, instructions with special characteristics are needed to meet the particular demands of processing audio signals. For instance, ASPs require a constant output sample rate since delays in or deviation from the ASP's output sample rate result in unwanted audible gaps or signal distortion. A 10 constant output sample rate is usually ensured by executing the same number of instruction for each sound effects program, where each instruction takes the same amount of time to execute.

15 Conventional DSP conditional instructions such as IF/ELSE IF/ELSE instructions cannot be easily used in ASPs since the number of executed instructions may not be the same as programs not having the conditional instruction, or the 20 number of executed instructions within the particular program may be different depending upon if the condition is TRUE or FALSE. However, conditional instructions remain valuable programming tools in creating sound effects. Therefore, a 25 need exists for a conditional instruction which when executed, executes the same number of instructions as those programs without the conditional instruction, and will execute the same number of instructions within the program regardless of the whether the condition's result is TRUE or FALSE.

30 Another requirement particular to ASPs is the conservation of the information content of signals having widely varying magnitudes. Conventional linear to logarithmic 35 conversion DSP instructions, such as the IEEE floating point instruction, generate a logarithmic representation having fixed exponent and mantissa fields. Because the exponent and mantissa fields are of a fixed length, signal information which is stored beyond those fields is lost.

What is needed is a linear to log conversion instruction which can define the exponent and mantissa fields of the log value, so that either field may be expanded or contracted to retain important signal information.

Further distinctive from conventional DSPs is the generation of special audio effects and waveshaping. Conventional DSP instructions do not provide the necessary waveshaping operations needed for creation of specialized audio effects.

5 Special ASP instructions could be added to an existing DSP instruction set, but the addition of a large number of instructions to the existing instruction set may be precluded by the limited size of the ASP's existing instruction memory. Although a small addition may not be  
10 precluded, any addition would require the allocation of a larger instruction memory within the ASP, driving up the ASP's fabrication cost.

15 What is needed is an ASP instruction set having a minimal number of multi-functional instructions, whereby a single instruction can be used to provide both conventional DSP and specialized operations. Further needed is the ability to reuse the instruction's specialized operations to formulate other specialized operations, thereby enabling the creation of a multitude of different sound effects with the same  
20 instruction set.

#### SUMMARY OF THE INVENTION

The invention provides an instruction set for control of an audio signal processor that allows for greater flexibility in generating desired sound effects. The instruction set serves as a multi-functional instruction base upon which other specialized sound effects can be constructed. Many instructions according to the present invention provide complex processing in a single instruction cycle. Also in the case of conditional execution, processing can be made to remain synchronous with programs not possessing conditional instructions.

35 In one embodiment of the present invention, a method for computing logical operations within a processor includes the steps of receiving a single machine instruction having a first address specifying a first operand, a second address specifying a second operand, and a third address specifying a third operand, and computing in a single instruction cycle a

result equivalent to a logical XOR operation between the third operand and an intermediate result of a logical AND operation between the first operand and the second operand.

In another embodiment of the invention, a method is provided for converting linear data into logarithmic data, the method including the steps of receiving a first instruction having a first address for specifying linear data, a second address for specifying a maximum exponent value, and a third address for specifying an output operand, and converting the linear data to logarithmic data by the steps of allocating a Q-bit long exponent field within the output operand, where Q is dependent upon the maximum exponent value, calculating a Q-bit long exponent value, calculating a mantissa value as a result of the calculation of the Q-bit long exponent value, and storing said exponent value and said mantissa value within said output operand.

In a third embodiment of the invention, a method for converting logarithmic data into linear data is presented and includes the steps receiving an instruction having a first address for specifying logarithmic data having an exponent value and a mantissa value, a second address for specifying a maximum exponent value, and converting the logarithmic data to linear data by the steps of defining the exponent value as having Q-bits, where Q is dependent upon the maximum exponent value, extracting said Q-bit long exponent value from the logarithmic data, defining the remaining bits of the logarithmic data as the mantissa value, and normalizing the mantissa value to a linear value.

In a fourth embodiment of the invention, a method is presented for skipping a subsequent instruction upon execution of a single instruction and includes the steps of receiving a first instruction having a first address for specifying status bits, and a second address for specifying a boolean equation, mapping the status bits into a bit string, applying the bit string to the boolean equation; and processing the subsequent instruction as a NULL instruction in the processor when the application of the bit string to the boolean equation results in a TRUE outcome.

A fifth embodiment of the invention provides a method for calculating a linear interpolation between two values A and Y, and includes the steps receiving in a processor a single instruction having a first address specifying a first operand A, a second address specifying a second operand X, and a third address specifying a third operand Y, and computing in a single instruction cycle, responsive to the instruction a result equivalent to  $A - X(A-Y)$ .

A further understanding of the nature and advantage of the invention herein may be realized by reference to the remaining portions of the specification and attached drawings.

#### BRIEF DESCRIPTION OF THE DRAWINGS

Fig. 1 depicts the instruction and data formats used in accordance with the invention.

Fig. 2 is a simplified block diagram of an audio signal processor architecture in accordance with the invention.

Fig. 3 illustrates a math unit of the previously described audio signal processor architecture in accordance with the invention.

Fig. 4A is a flow chart of an ANDXOR instruction in accordance with the invention.

Fig. 4B is a table describing the input values and output results of the ANDXOR instruction in accordance with the invention.

Fig. 4C depicts a simplified computer system for compiling source code into the ANDXOR instruction in accordance with the invention.

Fig. 5 is a flowchart of a LOG instruction in accordance with the invention.

Fig. 6 is a flowchart of an EXP instruction in accordance with the invention.

Fig. 7A is a flowchart of a SKIP instruction in accordance with the invention.

Fig. 7B depicts four, three term boolean equations used in processing the SKIP instruction in accordance with the invention.

Fig. 7C is a flowchart describing the steps of creating an IF/ELSE IF/ELSE logical block using the SKIP instruction in accordance with the invention.

Fig. 8 is a flowchart of an INTERP instruction in accordance with the invention.

#### 10 DESCRIPTION OF SPECIFIC EMBODIMENTS

The present invention is applicable to audio signal processors of all kinds. Some of the benefits provided by the invention are a wider degree of programming flexibility in creating sound effects, compatibility with constant rate audio sample generation, and a minimal requisite instruction memory space.

Disclosed herein is an ANDXOR instruction which provides a three operand logical operation resulting in many two operand logical results when one or more of the operands have specified values. Also disclosed is a LOG instruction which provides a linear to a logarithmic conversion whereby the user may define the maximum exponent value and mantissa field of the converted logarithmic value. Further disclosed is a SKIP instruction which provides data movement, conditional and non-conditional instruction execution without program branching, enabling synchronous program execution with programs not containing SKIP instructions. Additionally disclosed is a INTERP instruction which provides calculation of a scaled linear interpolation between two values in a single instruction cycle.

#### I. Audio Instruction Format

It will be useful to begin with a general description of instruction and data format used. Fig. 1 illustrates an instruction format 100 in accordance with the invention. The instruction includes an opcode 110, three input addresses 120, 130, 140, and one output address 150. The opcode 110 specifies the instruction's operation to the

processor, and preferably is 4-bits long. Addresses 120, 130, 140 and 150 specify spaces in a General Purpose Register (GPR) memory 230 (Fig. 2) within which data is stored. In the preferred embodiment, addresses 120, 130, 140 and 150 are 10-bits long and data stored at those address are 32-bits long. Data is stored in one of three data formats 160, 170 or 180 as detailed below. The instructions themselves are stored in a separate instruction memory 210, shown in Fig. 2.

## 10 II. Audio Processor Architecture

Fig. 2. illustrates an audio processor architecture for use with instructions having the above-described format. In this embodiment, the processor 200 includes an instruction memory 210 for instruction storage, a general purpose (GPR) memory 230 having an audio input line 205 for data input and storage, and a math unit 220 for performing logical and arithmetic operations.

Fig. 3 further details the architecture of the math unit 220 which includes a macReg block 350, a bank of computational units 370, and an output multiplexer 390. The macReg 350 is an input register which holds the input A, X, and Y operands retrieved from GPR memory 230. In the preferred embodiment, the macReg 350 includes a 67-bit accumulator register to store a full-width accumulated result of the last instruction's execution. The result may be used in subsequent operations as described below.

The computational units 370 include a macCore unit 371, a macXor unit 372, a macLog unit 373, a macExp unit 374 and a macCC unit 375. The macCore unit 371 is the primary multiplier/accumulator execution unit and performs fractional or integer multiplication with positive or negative accumulation. The macXor, macLog, macExp and macCC units 372, 373, 374 and 375 perform particular arithmetic and/or logical operations on the supplied data.

35 The math unit 220 also includes an operation decoder 320 and an output multiplexer 390. The operation decoder receives the instruction 212, reads the instruction's opcode 110, and transmits a control signal 330 to an output

5 multiplexer 390. Responsive to the control signal 330, the output multiplexer selects one of the five inputs supplied to it by the macCore, macXor, macLog, macExp, and macCC units 371, 372, 373, 374 and 375. The selected input is outputted as the R operand and is written to the R operand address 150 within the GPR memory 230.

10 Upon output of the R operand, the output multiplexer 390 generates a Condition Code operand (cc\_reg operand) 380 which is latched into the macCC unit 375. The cc\_reg operand 380 is a record of the status/condition of the resulting data (R operand), and consists of five condition code or "CC-bits." In the preferred embodiment, five CC-bits are used to monitor the resultant data: Borrow, Saturate, Minus, Zero and Normalized. When high, the "Borrow" bit indicates the result 15 of any subtraction has underflowed; the "Saturate" bit indicates the R operand has overflowed its 32-bit field; the "Minus" bit indicates the result is negative; the "Zero" indicates all zeros have been written to the specified R operand address; and the "Normalized" bit indicates the R 20 operand has undergone a binary point normalization. Each cc\_reg operand may contain all, several or none of the condition bits as explained below. While it is understood that all cc\_reg operands may not contain all five CC-bits, it will be assumed so for purposes of this description. The 25 cc\_reg operands are stored in the format 170, shown in Fig. 1.

30 In operation, the math unit 220 receives an instruction 212 from an instruction memory 210 to perform a particular operation on audio data stored in GPR memory 230. The instruction 212 includes an opcode 110, and the GPR address locations 120, 130 and 140 of input operands A, X and Y to be processed. Additionally included in the instruction 212 is a R operand address 150 where the result of the processing is to be written.

35 The math unit 220 retrieves the A, X, and Y operands from the GPR memory 230 and stores the data in the macReg 350 (Fig. 3). The macReg 350 supplies these operands to the computational units 371, 372, 373, 374 and 375 when requested. In the preferred embodiment, each computation unit receives

the A, X, and Y operands in parallel. The macCore, macXor, macLog, macExp, and macCC units 371, 372, 373, 374, and 375 each generates its own output, which are supplied to the output multiplexer 390.

5 A operation decoder 320 receives the instruction 212, reads the instruction opcode 110, and sends a control signal 330 to the output multiplexer 390 controlling which output of the computational units 370 will be selected. The output multiplexer 390 writes the selected data as the R 10 operand to the address location 150 specified in the instruction 212. A cc\_reg operand 380 indicating the status of the R operand is saved to the macCC unit 375, as described above.

15 In the preferred embodiment, the aforementioned steps of receiving an instruction 212 from the instruction memory 210, retrieving the A, X and Y operands from GPR memory 230, generating outputs from the computational units, selecting the desired output, writing the R operand to the GPR address specified in the instruction's R operand address 150, 20 and storing a cc\_reg operand 380 in the macCC unit 375, collectively occur in one instruction cycle.

### III. Audio Instructions and Processor Operation

25 The audio instructions will now be described with reference to the audio signal processor shown in Figs. 1 and 2. The present instructions, however, are not limited to this particular audio processor, and the instruction's execution in conjunction therewith is intended only as one of many possible implementations of the audio instructions.

30 The audio processor 200 operates using a set of instructions stored within the instruction memory 210 having the above-described format 100, Fig. 1. In the preferred embodiment, the stored instruction set includes general purpose instructions and special instructions, both of which 35. are described below.

#### A. ANDXOR Instruction

The ANDXOR instruction allows calculation of a variety of different logical results using a single logical instruction. The ANDXOR instruction 212 has an instruction format 100 shown in Fig. 1.

Instruction operation is described in the flowchart of Fig. 4A. At step 402, an ANDXOR instruction specifying three input operands A, X and Y, and one output operand R is received into the processor. In the preferred embodiment, the A, X and Y operands have the data format 160. Next, the specified A, X and Y operands are retrieved. Subsequently, two logical operations are performed. The first logical operation (step 406) is a logical AND operation on the A and X operands. An XOR operation is subsequently performed (step 408) on the first result and the Y operand, yielding a second result. The second result is described by the equation 2:

$$(2) \text{ Result} = (\text{A AND X}) \text{ XOR Y}$$

In the preferred embodiment, the macXor unit 372 calculates equation 2.

Referring to the audio processor of Fig. 3, a control signal 330 is transmitted from the operation decoder 320 in response to the ANDXOR opcode and directs the multiplexer 390 to select the macXor output. The macXor output is written to the address specified in the R operand address 150. A cc\_reg operand 380 indicating the status of the R operand is saved to the macCC unit 375. In the preferred embodiment, the stored cc\_reg operand 380 is saved in the format 170 as shown in Fig. 1 and consists of the aforementioned Minus, Zero and Normalized CC-bits. Additionally preferred is that the steps of receiving the instruction, retrieving the A, X, and Y operands, performing the first and second logical operations and generating a result, selecting the result, writing the result to the R operand address, and saving to the macCC unit a cc\_reg operand

corresponding to the result collectively occur within one instruction cycle.

Fig. 4B illustrates the ANDXOR instruction's results. The ANDXOR instruction always performs the three operand instruction as shown in equation 2 above. However, when the X or Y operands are particular values, the result is equivalent to other useful logical operations. For instance, if the Y operand is a binary word composed of all zero bits, the macXor unit 372 performs an AND logical operation on the A and Y operands. If the X operand is composed of all one-bits, the macXor unit 372 performs a XOR logical operation on the A and Y operands. In this manner, the ANDXOR instruction can be used to perform a variety of logical operations normally requiring separate instructions.

The ANDXOR instruction may be generated by a compiler from other logical operations specified by source code. Fig. 4C illustrates a simplified representation of an internal architecture of a personal computer 410 for compilation of simple source code logical operations into the ANDXOR instruction. Computer 410 includes a keyboard 412, a fixed disk 414 in which a compiler program is operatively disposed, and a system memory 416. Of course, many other computer configurations could be used with the present invention.

Via the keyboard 412, the user enters a particular logical operation, such as "A AND B" in a source code language such as FORTRAN or C. Upon compilation, the compiler program translates the logical operation into an ANDXOR instruction containing the ANDXOR instruction opcode, the result address field, input address fields for the variables A and B, and a third input address field specifying a binary zero word. When the compiled instruction is executed within a processor such as the audio signal processor described herein, the result becomes A AND B as originally composed in the source code.

Other logical operations may be implemented using the ANDXOR instruction through the above described method. For instance, the logical operation "A XOR B" can be entered in a source code language, which upon compilation, is

translated into the ANDXOR instruction having an X operand of all binary ones. A "A NAND X" operation can be obtained using source code compiled into the ANDXOR instruction having a Y operand of all binary one-bits. Similarly, a "NOT A" 5 operation is calculable in source code by compiling the source code into an ANDXOR instruction when the X and Y operands are both composed of all binary one bits.

The logical operation "A OR Y" may be obtained using source code which when compiled specifies an X operand and the 10 negation of the X operand as the Y operand. The negated X operand may either be specified by the programmer if the value has been predefined, or the compilation can occur in two steps where the X operand is determined first and loaded and its negation is determined second and loaded as the Y operand.

15

#### B. LOG Instruction

The LOG instruction is a linear to logarithmic conversion instruction in which the user can define the maximum exponent value and the mantissa length of the 20 converted logarithmic value. The instruction is useful in dynamic signal processing where linear to log dB conversions are necessary. Additionally, by allowing the programmer to vary the maximum exponent value of the logarithmic audio data, the LOG instruction can also be used to construct a wide 25 variety of waveshapes and special audio effects.

Fig. 5 is a flowchart which describes the operation of the LOG instruction. At step 502, a LOG instruction is received which specifies three input operands A, X and Y, and one output operand R. The A operand is the linear data to be 30 converted; the X operand specifies the maximum allowable exponent value of the converted logarithmic data; the Y operand is a format word which controls the arithmetic sign of the resulting logarithmic data; and the R operand is the resulting logarithmic data.

35 The logarithmic data (R operand) has a data format 180 shown in Fig. 1. The data format 180 includes a sign field 181, an exponent field 182, and a mantissa field 183.

5       Once the LOG instruction is received into the processor, the A, X and Y operands are retrieved at step 504. Subsequently at step 506, Q-bits are allocated to the exponent field 182 of the R operand, where Q is derived from the maximum exponent value (X operand). In the preferred embodiment, Q is the minimum number of bits needed to represent the maximum exponent value. In the preferred embodiment, Q ranges from 2 to 5 bits, allowing a maximum exponent value of 2 to 31.

10

15       Also at step 506, S bits are allocated to a sign field 181 of the R operand to indicate the sign of the logarithmic data. Inclusion of the sign bit allows pseudo-logarithmic conversion of negative values equivalent to applying an absolute value function on A operands having negative values, applying the logarithmic conversion, and then 20 performing sign restoration or transformation to create a signed result operand R. In the preferred embodiment, S is 1, allowing a sign field one bit wide.

25       The remaining bit spaces in the R operand 180 form the mantissa field 183 as shown in step 506. In the preferred embodiment, the mantissa field is 26-29 bits wide.

30       Once the sign, exponent, and mantissa field widths 181, 182 and 183 are defined within the R operand 180, the actual logarithmic value, defined by the exponent value 182A and mantissa 183A is calculated. First in step 508, the sign 35 of the linear data is stored. Next in step 510, an absolute value function is applied to the linear data. The linear data is subsequently normalized by shifting its most significant non-zero bit until it reaches the binary point or until the number of shifts equals the maximum exponent value (X operand), as shown in steps 512 and 514. A temporary exponent value is formed by subtracting the number of shifts from the maximum exponent value (step 516).

40       The mantissa 183A of the R operand 180 results from the shifted bits of the normalized data. If the number of shifts required for normalization is less the maximum exponent value (step 520), the most significant bit of the normalized data is removed, the data is shifted one additional position,

and the temporary exponent value is increased by one. In this case, the mantissa is said to posses an "implied 1" in a position one bit more significant than that actually retained by the mantissa value 183A.

5 If the mantissa field 183 has insufficient bit spaces to accommodate all of the mantissa bits 183A (step 522), the outstanding least significant bits are truncated. The final shifted and truncated mantissa value forms the mantissa 183A of the R operand 180. The last temporary 10 exponent value becomes the exponent value 182A and is stored in the exponent field 182 of the R operand 180.

Finally, the two least significant bits (LSB) of the format word (Y operand) are examined along with the stored sign bit 181A of the original linear data to determine what 15 sign transformation to apply to the R operand 180. The R operand 180 is transformed into its binary 1's complement value (step 524) if the two LSBs of the format word are "00" and the original sign bit 181A is "1", or if the format word bits are "11" and the original sign bit 181A is "0", or if the 20 format word bits are "10". In all other cases the transformation preserves the original values of the sign, exponent value and mantissa 181A, 182A and 183A. The output of the transformation is the R operand 180.

In the preferred embodiment, the above-mentioned 25 steps of allocating the exponent, sign and mantissa fields, calculating the exponent value and mantissa of the logarithmic data, and performing the sign transformation are executed within the macLog unit 373. The resulting logarithmic data (R operand) is outputted by the macLog unit 373.

30 Referring now to the audio processor of Fig. 3, a control signal 330 is transmitted from the operation decoder 320 in response to the LOG opcode and directs the multiplexer 390 to select the macLog output. The macLog output containing the logarithmic data is written to the address specified in the R operand address 150. A cc\_reg operand 380 indicating the status of the R operand is saved to the macCC unit 375. 35 In the preferred embodiment, the cc\_reg operand is saved in

the format 170 as shown in Fig. 1 and consists of the aforementioned Minus, Zero and Normalized CC bits.

Additionally preferred is that the steps of receiving the LOG instruction, retrieving the A, X and Y operands, allocating Q-bits to an exponent field of the R operand based on the value of the X operand, allocating S-bits to a sign field of the R operand, allocating the remaining bits to a mantissa field of the R operand, calculating the exponent value and mantissa of the logarithmic data, performing the sign transformation, storing the logarithmic data as the R operand to the specified address, and saving to the macCC unit a cc\_reg operand corresponding to the logarithmic data collectively occur within one instruction cycle.

15 C. EXP Instruction

The EXP instruction is used to convert logarithmically encoded data, like that produced as the output of the LOG instruction, back into a linear representation. Note that executing the EXP instruction on logarithmic data previously converted by the LOG instruction may not reconstruct the original linear data perfectly, since during the logarithmic conversion some signals may exceed the allowed mantissa width and some less significant bits will be lost. After reconversion with the EXP instruction, the loss of the less significant bits may result in the reconverted linear data differing in small magnitude from the original linear data.

Fig. 6 illustrates the operation of the EXP instruction. Initially at step 602, an EXP instruction specifying the EXP opcode, three input operands A, X and Y, and one output operand R is received into the processor. The A operand is the logarithmic data to be converted; the X operand specifies the maximum possible exponent value of the logarithmic data; the Y operand is a format word which controls the arithmetic sign of the resulting linear data; and the R operand is the resulting linear data.

The logarithmic data (A operand) has a data format 180 shown in Fig. 1. The data format 180 includes an S-bit wide sign field 181, a Q-bit wide exponent field 182, and a mantissa field 183. In the preferred embodiment, S is 1, 5 allowing for a one bit wide sign field.

Once the EXP instruction is received into the processor, the A, X and Y operands are retrieved (step 604). Next in step 606, the most significant bit of the S-bit sign field 181 of the logarithmic data in the A operand is 10 examined, and stored away for future use. In the preferred embodiment, if the bit is a '1' then a binary 1's complement operation is applied to the A operand data and the result is stored in an Input operand. If the bit is a '0', then the Input operand receives an unaltered copy of the A operand 15 data.

Subsequently in step 608, an absolute value operation is applied to the Input operand. Next, Q-bits of the exponent field 182 of the Input operand are defined and extracted (step 610). The defined and extracted Q-bits are 20 based on the maximum exponent value (X operand). In the preferred embodiment, Q is the minimum number of bits needed to represent the maximum exponent value. In the preferred embodiment, Q ranges from 2 to 5 bits, allowing a maximum exponent value of 2 to 31.

25 The mantissa value 183A, which is by definition all the bits in the logarithmic word 180 that are less significant than the exponent field, is extracted from the mantissa field 183 of the Input operand (step 610). If the extracted exponent value is not zero, a '1' bit is appended to the mantissa in 30 the most significant bit position, and the exponent value is decreased by 1, as shown in step 612. The appended '1' bit restores the original mantissa's most significant "implied 1." The resulting exponent value is then subtracted from the maximum exponent value (X operand), resulting in a shift 35 count, which ranges from zero to the maximum exponent value (step 614).

The resulting mantissa value is aligned at position N-1 of an N bit linear format word 160, producing a positive,

normalized 2's complement linear value (step 616). In the preferred embodiment,  $N = 32$ . The bits in the linear word which are less significant than the mantissa bits are comprised of zeros. The normalized linear word is then 5 shifted in a less-significant direction for a number of bit positions equal to the shift count, resulting in a de-normalized linear value (step 618).

Finally, the least significant two bits of the format word (Y operand) are examined along with the stored 10 sign bit of the original logarithmic data to determine what sign transformation to apply to the de-normalized linear value. The linear value is transformed into its binary 1's complement (step 620) if the format word bits are "00" and the original sign bit is "1", or if the format word bits are "11" 15 and the original sign bit is "0", or if the format word bits are "10". In all other cases the transformation preserves the original bit values of the de-normalized linear value. The output of the transformation represents the final value of the R operand 180.

20 In the audio processor shown in Fig. 3, the above steps of logarithmic to linear conversion are performed in the macExp unit 373. The macExp unit 373 then outputs the restored linear data for selection by the output multiplexer 390.

25 After the macExp unit 373 outputs the restored linear data, a control signal 330 is transmitted from the operation decoder 320 in response to the EXP opcode and directs the multiplexer 390 to select the macExp output. The macExp output is written to the address specified in the R 30 operand address 150. A cc\_reg operand 380 indicating the status of the R operand is saved to the macCC unit 375. In the preferred embodiment, the cc\_reg operand 380 is saved in the format 170 as shown in Fig. 1 and consists of the aforementioned Minus, Zero and Normalized CC-bits.

35 Additionally preferred is that the steps of receiving the EXP instruction, deriving the exponent, shifting the mantissa, optionally complementing the restored linear data, selecting the restored data output, writing the restored

linear data to a specified R operand address, and storing to the macCC unit a cc\_reg operand corresponding to the restored linear data collectively occur within one instruction cycle.

### C. SKIP Instruction

5 The SKIP instruction is used for data movement and execution of instructions without program branching.

Instruction execution without program branching is obtained by processing each skipped instruction as a null instruction, further explained below. Data movement occurs as a consequence of implementing the SKIP instruction, further explained below. The SKIP instruction has the instruction format 100 as shown in Fig. 1.

Fig. 7A shows a flowchart of the SKIP instruction.

At step 702, a SKIP instruction specifying three input operands A (cc\_reg), X (count), and Y (cc\_test) and output operand R is received into the processor 200. The A operand (cc\_reg operand) contains the aforementioned CC-bits (Borrow, Saturate, Minus, Zero and Normalized) which indicate the status of previously outputted R operand. The cc\_reg operand is saved in the data format 170 shown in Fig. 1.

The X operand (count operand) identifies the number of instructions to be skipped if an equation specified by the Y operand (cc\_test) has a TRUE outcome. Both the cc\_test and count operands are stored in data format 160.

25 Once the SKIP instruction is received, the cc\_reg, count and cc\_test (A, X and Y) operands are retrieved in step 704. In the audio processor shown in Fig. 3, the count and cc\_test operands are retrieved from GPR memory 230. The cc\_reg operand may be retrieved either from the macCC unit 375 or from the GPR memory 230. The cc\_reg operand 380 stored in the macCC unit 375 contains the Condition Code bits from the R operand generated from last executed instruction. The cc\_reg operand stored in the GPR memory 230 contains Condition Code bits of an earlier instruction's result. Storage within the GPR memory 230 is accomplished by a secondary MOVE operation of the SKIP instruction, described below, or by any other instruction whose output is an appropriate bit pattern for

application as the cc\_reg operand of a subsequent SKIP instruction. Selection of the desired cc\_reg operand is accomplished by specifying an address in the A operand address 120 corresponding to the GPR memory 230 or macCC unit 375 address location.

5 The SKIP instruction provides a secondary MOVE operation whereby the A operand (cc\_reg) is moved to R operand (step 706). In the audio processor shown in Fig. 3, the cc\_reg operand is written to the R operand address 150 in GPR memory 230. If the cc\_reg operand was retrieved from the 10 macCC unit 375, it will be moved to the GPR memory address 150 specified in the R operand. In this manner, a previous instruction's cc\_reg operand which has been stored in the macCC unit 375 can be moved into the GPR memory 230 for later 15 retrieval using the SKIP instruction.

Once the cc\_test, count and cc\_reg operands are retrieved, a boolean equation is selected by the cc\_test 20 operand, shown in step 708. In the preferred embodiment of Fig. 7B, the selected boolean equation 720 is composed of three 10-bit factors. Each factor contains the original five CC-bit terms and their inverses. As shown, each boolean 25 equation is arranged as the sum, product, or combination of the five CC-bits and their inverses, allowing for a variety of different testing conditions.

25 In the preferred embodiment, the cc\_test operand is also stored in the data format 160 and includes a 2-bit field to identify which one of the four possible forms of boolean 30 equations should be used for the test. The remaining bits of the cc\_test operand indicate the mapping of the original 5 CC-bits and their inverses into the 30 1-bit operands of the selected boolean equation.

35 After a boolean equation is selected, the addressed cc\_reg operand supplies its CC-bits which are then mapped into a longer CC-bit string (step 710). In the preferred embodiment, the five CC-bits are mapped into thirty-bit CC-bit string. The thirty mapped CC-bits include up to 3 copies of the original 5 CC-bits and their inverses, and are assigned one-to-one to their respective operands within the boolean

equation 720 (Fig 7B.) Specific cc\_test values may be used to provide special features. For instance, a cc\_test value of all 1-bits corresponds to an unconditional TRUE ("skip") condition, and a cc\_test value of all 0-bits corresponds to an unconditional FALSE ("do not skip") condition.

Once the CC-bit string has been mapped, it is applied to the selected boolean equation (step 712). If the result of the application is FALSE, normal processing resumes and the next instruction is executed as defined (step 719). If the outcome is TRUE, the next N instructions will be "skipped."

In the audio processor shown in Fig. 3, the step of "skipping" N instructions is accomplished within the macCC unit 375. An internal counter is loaded with the count operand N (step 714). The macCC unit 375 subsequently processes each instruction as a null instruction (step 716), decrements the skip counter (step 718), and continues this process until the skip counter decrements to from N to zero.

The macCC unit 375 "skips" an instruction by processing it as a null instruction. A null instruction is an instruction which has the same process duration as any other instruction, but performs no operation. In one embodiment, the null instruction generates no output result. In another embodiment, the null instruction does not write its result to memory. In a third embodiment, the first null instruction skips to the N<sup>th</sup> subsequent instruction at which point the processor waits until the processing time for the N skipped instructions elapses, at which time the N+1<sup>st</sup> instruction is executed. Other configurations, such as the conventional NOP instruction are also possible and the described embodiments are not exhaustive.

In the preferred embodiment, the steps of receiving the SKIP instruction, retrieving the cc\_reg, count and cc\_test operands, writing the cc\_reg operand to the output operand, selecting the boolean equation as defined by cc\_test operand, selecting the cc\_reg operand, mapping the cc\_reg bits (defined by the cc\_test operand bits) to the CC-bits, applying the CC-bits to the boolean equation, and generating a result

collectively occur within the one instruction cycle. Further preferred is that each subsequently "skipped" (null) instruction, if any, has a processing duration of one instruction cycle.

5 It should be noted that during the processing of the SKIP or "skipped" instructions, the output multiplexer 390 does not generate a cc\_reg word 380 to be fed back into the macCC unit 375, and SKIP instructions which are themselves "skipped" are processed as null instructions and do not cause 10 the program to branch off the original skip routine.

15 The SKIP instruction can be used to create IF/ELSE IF/ELSE logical blocks as shown in Fig. 7C. For instance, it may be desirable to execute the logical sequence "IF CC1 <execute 1st block> ELSE IF CC2 <execute 2nd block> ELSE <execute 3rd block>". In the preferred embodiment, it is desired that the 1st block of instruction are executed only if the result of CC1 is TRUE. However, the SKIP instruction is 20 designed to "skip" on a TRUE result. To satisfy both requirements, the CC1 condition is negated by forming a logically inverted boolean equation representing  $\neg CC1$ , which is stored in the cc\_test operand. This allows the SKIP instruction to "skip" on a TRUE result of  $\neg CC1$  which is equivalent to "executing" on a TRUE result of CC1. Thus a first SKIP instruction conditioned on cc\_test condition  $\neg CC1$  25 is executed. As described above, the SKIP instruction retrieves the stored cc\_reg operand and generates mapped CC-bits therefrom. The mapped CC-bits are applied to a boolean equation, defined by the cc\_test operand, and a TRUE or FALSE result occurs.

30 Referring to Fig. 7C, if CC1 is FALSE, the subsequent block of instructions are executed (step 750). Execution of the first block of instructions represents the IF sequence of the IF/ELSE IF/ELSE block. The last instruction in the IF block is an unconditional SKIP instruction which 35 serves as a JUMP instruction to the end of the IF/ELSE IF/ELSE block (step 752). As described above, an unconditional SKIP instruction can be created by mapping all 1-bits to the boolean equation 720.

At step 754, a second SKIP instruction allows conditional execution of a second set of (ELSE IF) instructions based on an entirely independent condition CC2 that was set before the first IF statement was executed.

5 Since the subsequent instruction skipping does not generate cc\_reg operands, the skipping of the first block does not alter the cc\_reg stored in the macCC unit 375. Therefore at step 754, it may again be selected and tested against the CC2 condition specified in the ELSE IF block by using the second 10 SKIP instruction with a cc\_test operand representing ~CC2, which is logically inverted from CC2 for the aforementioned reasons. Upon a FALSE outcome, the ELSE IF instruction block is executed, shown in step 756. Upon execution of the last instruction of the ELSE IF block, an unconditional SKIP 15 instruction serves as a JUMP out of the IF/ELSE IF/ELSE block (step 758).

Instructions in the ELSE IF block are executed on CC2 being TRUE or equivalently on ~CC2 being FALSE. If both conditions ~CC1 and ~CC2 are TRUE (both CC1 and CC2 are 20 FALSE), the SKIP instruction skips to and executes the ELSE block of instructions (steps 760 and 762). Execution of the last instruction in the ELSE block terminates the IF/ELSE IF/ELSE block and normal processing continues from there (step 764).

25 D. INTERP Instruction

The INTERP instruction allows calculation of a scaled linear interpolation between two operands A and Y. The INTERP instruction can also implement first order recursive and non-recursive low-pass filters.

30 Fig. 8 is a flowchart of an INTERP instruction when used to generate a linear interpolation or a first order recursive lowpass filter. Initially in step 802, a INTERP instruction specifying the three input operands A, X, and Y and one output operand R is received into the processor. Next 35 as shown in steps 804 and 806, the specified A, X and Y operand are retrieved and an operation performed represented by equation 3:

(3) A - X(A-Y)  $\rightarrow$  Result

The result (step 808) indicates the linear interpolation between the A operand and the Y operand, scaled by the X operand.

5 In the audio processor shown in Fig. 3, the A, X and Y operands have data formats 160 and are supplied to the macCore unit 371 where the arithmetic operation shown in equation 3 is performed. A control signal 330 is transmitted from the operation decoder 320 in response to the INTERP 10 opcode and directs the output multiplexer 390 to select the macCore output. The macCore output is written to the address specified in the R operand address 150. Upon output of the R 15 operand, a cc\_reg operand 380 containing the R operand's CC-bits is saved into the macCC unit 375. The stored cc\_reg operand 380 has the format 170 as shown in Fig. 1 and contains the aforementioned Zero, Borrow, Saturate, Minus, and Normalized CC-bits.

20 In the preferred embodiment, the aforementioned steps of receiving the INTERP instruction, retrieving the A, X, and Y operands, calculating the result of equation 3, 25 selecting the macCore output, writing the macCore output to the R operand address, and storing into the macCC unit a cc\_reg operand containing the CC-bits of the macCore output collectively occur within one instruction cycle.

30 If the R operand is fed back into the A operand (step 810), a first-order recursive lowpass filter is created. In the preferred embodiment of Fig. 3, this step is realized in the INTERP instruction by specifying the A operand address 120 as the R operand address.

35 If the A operand is a one sample period delayed version of the Y operand, application of the above steps 802-808 results in a non-recursive first-order lowpass filter. This step can be realized by specifying in the INTERP instruction an A operand address 120 corresponding to the location where the one sample period delayed version of the Y operand 222 is stored. In this embodiment, the additional step of retrieving a one sample period delayed version of the

Y operand also occurs within the same instruction cycle as the previously mentioned steps in sequence 802-808.

While the above is a complete description of the preferred embodiments of the invention, various alternatives 5 modifications and equivalence may be used. For example, any of the disclosed instructions could be used by a processor not specifically designed for processing audio signals, but which has similar requirements of instruction functionality, reuse and user-defined flexibility. It should be evident that the 10 present invention is equally applicable by making appropriate modifications to the embodiments described above. Therefore, the above description should not be taken as limiting the scope of the invention which is defined by the metes and bounds of the appended claims.

WHAT IS CLAIMED IS:

1           1. A method for computing logical operations  
2           within a processor comprising the steps of:

3           receiving, in said processor, a single machine  
4           instruction comprising:

5           a first address for specifying a first operand;  
6           a second address for specifying a second

7           operand; and

8           a third address for specifying a third operand;  
9           and

10           computing in a single instruction cycle of said  
11           processor, a result equivalent to a logical XOR operation  
12           between said third operand and an intermediate result of a  
13           logical AND operation between said first operand and said  
14           second operand.

1           2. A method of compiling source code into  
2           instructions belonging to an instruction set of a processor  
3           comprising the steps of:

4           receiving a source code instruction for performing  
5           an AND operation between a first operand and a second operand;

6           compiling said source code instruction into a single  
7           instruction code specifying an instruction of said processor  
8           instruction set, said single instruction code comprising a  
9           first address for specifying said first operand, a second  
10           address for specifying said second operand, and a third  
11           address for specifying a third operand, whereupon said receipt  
12           of said single instruction code by said processor, said  
13           processor computes in a single instruction cycle a result  
14           equivalent to a logical XOR operation between said third  
15           operand, and an intermediate result of a logical AND operation  
16           between said first and second operands;

17           specifying said first operand as comprising a first  
18           value;

19           specifying said second operand as comprising a  
20           second value; and

specifying said third operand as comprising zero bits.

3. A method of compiling source code into instructions belonging to an instruction set of a processor comprising the steps of:

receiving a source code instruction for performing a NAND operation between a first operand and a second operand;

compiling said source code instruction into a single instruction code specifying an instruction of said processor instruction set, said single instruction code comprising a first address for specifying said first operand, a second address for specifying said second operand, and a third address for specifying a third operand, whereupon said receipt of said single instruction code by said processor, said processor computes in a single instruction cycle a result equivalent to a logical XOR operation between said third operand, and an intermediate result of a logical AND operation between said first and second operands;

specifying said first operand as comprising a first value;

specifying said second operand as comprising a second value; and

specifying said third operand as comprising one bits.

4. A method of compiling source code into instructions belonging to an instruction set of a processor comprising the steps of:

receiving a source code instruction for performing an XOR operation between a first operand and a third operand;

compiling said source code instruction into a single instruction code specifying an instruction of said processor instruction set, said single instruction code comprising a first address for specifying said first operand, a second address for specifying a second operand, and a third address for specifying said third operand, whereupon said receipt of said single instruction code by said processor, said processor

13           computes in a single instruction cycle a result equivalent to  
14           a logical XOR operation between said third operand, and an  
15           intermediate result of a logical AND operation between said  
16           first and second operands;

17               specifying said first operand as comprising a first  
18           value;

19               specifying said second operand as comprising all one  
20           bits; and

21               specifying said third operand as comprising a second  
22           value.

1               5. A method of compiling source code into  
2           instructions belonging to an instruction set of a processor  
3           comprising the steps of:

4               receiving a source code instruction for performing a  
5           NOT operation on a first operand;

6               compiling said source code instruction into a single  
7           instruction code specifying an instruction of said processor  
8           instruction set, said single instruction code comprising a  
9           first address for specifying said first operand, a second  
10           address for specifying a second operand, and a third address  
11           for specifying a third operand, whereupon said receipt of said  
12           single instruction code by said processor, said processor  
13           computes in a single instruction cycle a result equivalent to  
14           a logical XOR operation between said third operand, and an  
15           intermediate result of a logical AND operation between said  
16           first and second operands;

17               specifying said first operand as comprising a first  
18           value;

19               specifying said second operand as comprising one  
20           bits; and

21               specifying said third operand as comprising one  
22           bits.

1               6. A method of compiling source code into  
2           instructions belonging to an instruction set of a processor  
3           comprising the steps of:

4                   receiving a source code instruction for performing  
5                   an OR operation between a first operand and a third operand;  
6                   compiling said source code instruction into a single  
7                   instruction code specifying an instruction of said processor  
8                   instruction set, said single instruction code comprising a  
9                   first address for specifying said first operand, a second  
10                  address for specifying a second operand, and a third address  
11                  for specifying said third operand, whereupon said receipt of  
12                  said single instruction code by said processor, said processor  
13                  computes in a single instruction cycle a result equivalent to  
14                  a logical XOR operation between said third operand, and an  
15                  intermediate result of a logical AND operation between said  
16                  first and second operands;  
17                  specifying said first operand as comprising a first  
18                  value;  
19                  specifying said second operand as comprising a  
20                  second value; and  
21                  specifying said third operand as comprising the  
22                  negation of said second value, wherein said negation of said  
23                  second value is predefined.

1                   7. A method of compiling source code into  
2                   instructions belonging to an instruction set of a processor  
3                   comprising the steps of:

4                  receiving a source code instruction for performing  
5                  an OR operation between a first operand and a third operand;  
6                  compiling said source code instruction into a single  
7                  instruction code specifying an instruction of said processor  
8                  instruction set, said single instruction code comprising a  
9                  first address for specifying said first operand, a second  
10                 address for specifying a second operand, and a third address  
11                 for specifying said third operand, whereupon said receipt of  
12                 said single instruction code by said processor, said processor  
13                 computes in a single instruction cycle a result equivalent to  
14                 a logical XOR operation between said third operand, and an  
15                 intermediate result of a logical AND operation between said  
16                 first and second operands;

17                   specifying said first operand as comprising a first  
18                   value;  
19                   specifying said second operand as comprising a  
20                   second value;  
21                   negating said second value; and  
22                   specifying said third operand as comprising said  
23                   negated second value.

1                   8. A method for converting linear data into  
2                   logarithmic data comprising the steps of:

3                   receiving into a processor, a first instruction,  
4                   said first instruction comprising:

5                   a first address for specifying a first operand  
6                   comprising linear data;  
7                   a second address for specifying a second  
8                   operand comprising a maximum exponent value; and  
9                   a third address for specifying an output  
10                  operand; and

11                  converting said linear data to logarithmic data  
12                  having an exponent value and a mantissa value, said step of  
13                  converting comprising the steps of:

14                  allocating a Q-bit long exponent field within  
15                  said output operand, wherein Q is dependent upon said  
16                  maximum exponent value;

17                  calculating a Q-bit long exponent value;

18                  calculating a mantissa value as a result of  
19                  said calculation of said Q-bit long exponent value; and  
20                  storing said exponent value and said mantissa  
21                  value within said output operand.

1                   9. The method of claim 8 wherein said instruction  
2                   further comprises a fourth address for specifying a fourth  
3                   operand comprising a format word, said method further  
4                   comprises the steps of:

5                   allocating a S-bit long sign field to said output  
6                   operand;

7                   storing zeros in said S-bit long sign field of said  
8                   output operand;

10. The method of claim 8 wherein said step of calculating a Q-bit long exponent value comprises the steps of:

detecting the most significant bit in said linear data; and

shifting said most significant bit to the binary floating point, wherein the number of bit positions shifted does not exceed said maximum exponent value;

defining a temporary exponent value as the difference between the maximum exponent value and the number of bit positions shifted;

calculating said Q-bit long exponent value based upon said temporary exponent value, wherein if said linear data is not normalized, said temporary exponent value comprises said exponent value, and wherein if said linear data is normalized, said most significant bit is removed, said linear data is shifted one additional position, said temporary exponent value increments by one, and said temporary exponent value comprises said Q-bit long exponent value.

11. The method of claim 8 wherein said first instruction further comprises an opcode comprising LOG, and wherein said N is a value of thirty-two, and said Q is a value between two and five inclusive.

12. The method of claim 8 wherein said steps of receiving and converting occur during a single instruction cycle.

1                   13. A method for converting logarithmic data into  
2 linear data comprising the steps of:

3                   receiving into a processor, a first instruction,  
4 said first instruction comprising:

5                   a first address for specifying a first operand  
6 comprising logarithmic data having an exponent value and  
7 a mantissa value;

8                   a second address for specifying a second  
9 operand comprising a maximum exponent value; and

10                  converting said logarithmic data to linear data,  
11 said step of converting comprising the steps of:

12                  defining said exponent value as having Q-bits,  
13 wherein Q is dependent upon said maximum exponent value;

14                  extracting said Q-bit long exponent value from  
15 said logarithmic data;

16                  defining the remaining bits of said logarithmic  
17 data as said mantissa value; and

18                  normalizing said mantissa value to a linear  
19 value, wherein said normalization is based upon said Q-  
20 bit long exponent value.

1                   14. A method for skipping a subsequent instruction  
2 upon execution of a single instruction comprising the steps  
3 of:

4                   receiving into a processor a first instruction  
5 comprising:

6                   a first address for specifying a first operand  
7 comprising status bits; and

8                   a second address for specifying a second  
9 operand comprising a indicator for selecting a boolean  
10 equation;

11                  mapping said status bits into a bit string;

12                  applying said bit string to said boolean equation;

13                  and

14                  processing said subsequent instruction as a null  
15 instruction in said processor when said application of said  
16 bit string to said boolean equation results in a TRUE outcome.

1           15. The method of claim 14 wherein said instruction  
2 further comprises a third address, the method further  
3 comprising the step of writing said first operand to said  
4 third address.

1           16. The method of claim 14 wherein said steps of  
2 receiving, mapping, and applying collectively comprise one  
3 instruction cycle in duration.

1           17. The method of claim 14 wherein said step of  
2 processing comprises one instruction cycle in duration.

1           18. A method for skipping N subsequent instructions  
2 upon execution of a single instruction comprising the steps  
3 of:

4           receiving into a processor a first instruction  
5 comprising:

6           a first address for specifying a first operand  
7 comprising status bits;

8           a second address for specifying a second  
9 operand comprising an indicator for selecting a boolean  
10 equation; and

11           a third address for specifying a third operand  
12 comprising a value N;

13           mapping said status bits into a bit string;

14           applying said bit string to said boolean equation;

15           and

16           processing each of said N subsequent instructions as  
17 a null instruction when said application of said bit string to  
18 said boolean equation results in a TRUE outcome.

1           19. The method of claim 18 wherein said instruction  
2 further comprises a fourth address, the method further  
3 comprising the step of writing said first operand to said  
4 fourth address.

1                   20. The method of claim 18, wherein said steps of  
2 receiving, mapping, and applying comprise one instruction  
3 cycle in duration.

1                   21. The method of claim 18, wherein said step of  
2 processing each of said processed N instructions each comprise  
3 one instruction cycle in duration.

1                   22. A method for calculating a linear interpolation  
2 between two values A and Y, comprising the steps of:

3                   receiving in a processor, a single instruction  
4 comprising:

5                   a first address for specifying a first operand  
6                   A;

7                   a second address for specifying a second  
8                   operand X; and

9                   a third address for specifying a third operand  
10                   Y;

11                   computing in a single instruction cycle, responsive  
12 to said instruction a result equivalent to  $A - X(A-Y)$ .

1                   23. The method of claim 22 further comprising the  
2 step of replacing said first operand A with said third operand  
3 Y, whereby said result now represents a first order recursive  
4 low-pass filter output.

1                   24. The method of claim 22, wherein said first  
2 operand A comprises a one sample period delayed version of  
3 said third operand Y, whereby said result represents a first  
4 order non-recursive lowpass filter output.

1                   25. A processing unit for performing logical  
2 operations, said processing unit comprising:

3                   a memory unit for storing an instruction opcode, a  
4 first operand, a second operand and a third operand;

5                   an execution unit coupled to said memory unit for  
6 receiving said instruction opcode and said first, second and  
7 third operands, and for calculating, in response to said

8 instruction opcode, a logical result comprising a logical XOR  
9 operation between said third operand and an intermediate  
10 result, wherein said intermediate result comprises a logical  
11 AND operation between said first and said second operands.

1 26. A processing unit for converting linear data to  
2 logarithmic data, the processing unit comprising:

3 a memory unit for storing an instruction comprising:

4 an instruction opcode;

5 a first address for specifying a first operand  
6 comprising linear data; and

7 a second address for specifying a second  
8 operand comprising a maximum exponent value;

9 a third address for specifying an output  
10 operand; and

11 an execution unit coupled to said memory unit for  
12 receiving said instruction, and responsive to said instruction  
13 opcode, for allocating within said output operand a Q-bit  
14 exponent field and a mantissa field, wherein said Q is  
15 dependent upon said maximum exponent value, and for  
16 calculating a Q-bit exponent value and a mantissa value for  
17 storage within said exponent field and said mantissa field of  
18 said output operand.

1 27. A processing unit for converting logarithmic  
2 data to linear data, the processing unit comprising:

3 a memory unit for storing an instruction comprising

4 an instruction opcode,

5 a first address for specifying a first operand  
6 comprising logarithmic data having an exponent value and  
7 a mantissa value, and

8 a second address for specifying a second  
9 operand

10 comprising a maximum exponent value; and

11 an execution unit coupled to said memory unit for  
12 receiving said instruction, and responsive to said instruction  
13 opcode, for defining said exponent value as having Q-bits  
14 within said logarithmic data, wherein Q is dependent upon said

15 maximum exponent value, for extracting said Q-bit exponent  
16 value from said logarithmic data, for extracting the remaining  
17 bits of said logarithmic data as said mantissa value, and for  
18 normalizing said mantissa to said linear value based upon said  
19 extracted exponent value.

1               28. A processing unit for directing a processor to  
2 skip a subsequent instruction upon execution of a first  
3 instruction, the processing unit comprising:

4               a memory unit for storing a first instruction  
5 comprising:

6               an instruction opcode;

7               a first address for specifying a first operand  
8 comprising status bits; and

9               a second address for specifying a second  
10 operand comprising a indicator for selecting a boolean  
11 equation; and

12               an execution unit coupled to said memory unit for  
13 receiving said first instruction, and in response to said  
14 instruction opcode, for mapping said status bits into a bit  
15 string, for applying said bit string to said indicated boolean  
16 equation, and for processing said subsequent instruction as a  
17 null instruction when said application of said bit string to  
18 said boolean equation results in a TRUE outcome.

1               29. A processing unit for calculating the linear  
2 interpolation between two values A and Y, the processing unit  
3 comprising:

4               a memory unit for storing an instruction comprising:  
5               a first address for specifying a first operand  
6               A;

7               a second address for specifying a second  
8 operand X; and

9               a third address for specifying a third operand  
10 Y;

11               an execution unit coupled to said memory unit for  
12 receiving said instruction, and in response to said

13 instruction opcode, for calculating in a single instruction  
14 cycle a result equivalent to  $A - X(A-Y)$ .

1 30. A software product for use with a processor  
2 responsive to an instruction set, said product comprising:

3 a single instruction for controlling said processor,  
4 said single instruction comprising:

5 an instruction opcode for specifying the  
6 operation to be executed within the processor;

7 a first address for specifying a first operand,  
8 a second address for specifying a second

9 operand, and

10 a third address for specifying a third operand,

11 wherein upon receipt of said instruction opcode,  
12 said processor computes a result equivalent to a logical XOR  
13 operation between said third operand and an intermediate  
14 result, said intermediate result comprising a logical AND  
15 operation between said first operand and said second operand;  
16 and

17 a computer readable storage medium for storing said  
18 single instruction thereon.

1 31. A software product for use with a processor  
2 responsive to an instruction set, said product comprising:

3 an instruction belonging to said predetermined set  
4 of instructions for controlling said processor to convert, in  
5 a single instruction, linear data to logarithmic data having  
6 an exponent value and a mantissa value, said instruction  
7 comprising:

8 an instruction opcode for directing said  
9 processor to convert said linear data to said logarithmic  
10 data;

11 a first address for specifying said linear  
12 data;

13 a second address for specifying a maximum  
14 exponent value of said logarithmic data;

15 a third address for specifying said logarithmic  
16 data, further comprising:

an exponent field of Q bits in which said exponent value of said logarithmic data is stored, wherein said Q is dependent upon said maximum exponent power; and

a mantissa field in which said mantissa value of said logarithmic data is stored; and computer readable storage medium for storing said data.

32. A software product for use with a processor responsive to an instruction set, said product comprising:

an instruction belonging to said predetermined set of instructions for controlling said processor to convert, in a single instruction, logarithmic data to linear data, said instruction comprising:

an instruction opcode for directing said processor to convert said logarithmic data to said linear data;

a first address for specifying a maximum exponent value of said logarithmic data;

a second address for specifying said logarithmic data, further comprising:

an exponent value expressed in Q-bits, wherein said Q is dependent upon said maximum exponent power; and

a mantissa value; and

a third address for specifying said linear data; and

a computer readable storage medium for storing said instruction.

33. A computer program product for controlling a processor responsive to a predetermined set of instructions, said product comprising:

an instruction belonging to said predetermined set of instructions for controlling said processor to skip a subsequent instruction, said instruction comprising:

a first address for specifying a first operand

8 comprising an indicator for selecting a boolean equation,  
9 said boolean equation for generation a TRUE or FALSE  
10 outcome;

11 a second address for specifying a second  
12 operand comprising status bits, said status bits for  
13 creating a bit string, and said bit string for  
14 application to said boolean equation;

15 an instruction opcode for directing said  
16 processor to process a subsequent instruction as a null  
17 instruction if a TRUE outcome results from said  
18 application of said bit string to said boolean equation;  
19 and

20 a computer readable storage medium for storing said  
21 instruction.

1                   34. A software product for use with a processor  
2 responsive to an instruction set, said product comprising:

3 a single instruction specifying an instruction for  
4 said processor, said single instruction comprising:

5 a first address for specifying a first operand  
6 comprising a value A,

7                   a second address for specifying a second  
8                   operand comprising a value X, and

11                   wherein upon receipt of said instruction opcode,  
12    said processor computes a result equivalent to  $A - X(A-Y)$ ; and

13 a computer readable storage medium for storing s

single instruction thereon.

1/11



Fig. 1



Fig. 2



Fig. 3



Fig. 4A

| A | X         | Y         | Result          |
|---|-----------|-----------|-----------------|
| A | X         | Y         | (A AND X) XOR Y |
| A | X         | 0         | A AND X         |
| A | 0xFFFFFFF | Y         | A XOR Y         |
| A | 0xFFFFFFF | 0xFFFFFFF | NOT A           |
| A | X         | -X        | A OR Y          |
| A | X         | 0xFFFFFFF | A NAND X        |

Fig. 4B

5/11



FIG. 4C

SUBSTITUTE SHEET (RULE 26)

6/11



Fig. 5

7/11



Fig. 6

SUBSTITUTE SHEET (RULE 26)

8/11



Fig. 7A

9/11

720

|         |                                                                         |     |                                                                         |     |                                                                         |
|---------|-------------------------------------------------------------------------|-----|-------------------------------------------------------------------------|-----|-------------------------------------------------------------------------|
| Form 1: | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ | $+$ | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ | $+$ | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ |
| Form 2: | $(S + Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ | $*$ | $(S + Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ | $*$ | $(S + Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ |
| Form 3: | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ | $+$ | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ | $+$ | $(S * Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ |
| Form 4: | $(S + Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ | $*$ | $(S + Z + M + B + N + \bar{S} + \bar{Z} + \bar{M} + \bar{B} + \bar{N})$ | $*$ | $(S * Z * M * B * N * \bar{S} * \bar{Z} * \bar{M} * \bar{B} * \bar{N})$ |

Fig. 7B

10/11



Fig. 7C  
SUBSTITUTE SHEET (RULE 26)

11/11



Fig. 8

1st Order Non-Recursive LPF  
-01-  
1st Order Recursive LPF

## INTERNATIONAL SEARCH REPORT

International application No.  
PCT/US98/13823

## A. CLASSIFICATION OF SUBJECT MATTER

IPC(6) :G06F 09/305

US CL :395/564

According to International Patent Classification (IPC) or to both national classification and IPC

## B. FIELDS SEARCHED

Minimum documentation searched (classification system followed by classification symbols)

U.S. : 395/564

Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched

Electronic data base consulted during the international search (name of data base and, where practicable, search terms used)

APS

search terms: logical operation, instruction, operand, operand address, xor, single cycle.

## C. DOCUMENTS CONSIDERED TO BE RELEVANT

| Category* | Citation of document, with indication, where appropriate, of the relevant passages | Relevant to claim No. |
|-----------|------------------------------------------------------------------------------------|-----------------------|
| Y         | US 4,131,940 A (MOYER) 26 DECEMBER 1978, COL. 9, LINES 47-68.                      | 1, 25, 30             |
| Y         | US. 4,785,393 A (CHU ET AL) 15 NOVEMBER 1988, COL. 5, LINES 5-31.                  | 1, 25, 30             |

Further documents are listed in the continuation of Box C.

See patent family annex.

|     |                                                                                                                                                                     |     |                                                                                                                                                                                                                                              |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •   | Special categories of cited documents:                                                                                                                              | "T" | later document published after the international filing date or priority date and not in conflict with the application but cited to understand the principle or theory underlying the invention                                              |
| "A" | document defining the general state of the art which is not considered to be of particular relevance                                                                | "X" | document of particular relevance; the claimed invention cannot be considered novel or cannot be considered to involve an inventive step when the document is taken alone                                                                     |
| "E" | earlier document published on or after the international filing date                                                                                                | "Y" | document of particular relevance; the claimed invention cannot be considered to involve an inventive step when the document is combined with one or more other such documents, such combination being obvious to a person skilled in the art |
| "L" | document which may throw doubts on priority claim(s) or which is cited to establish the publication date of another citation or other special reason (as specified) | "&" | document member of the same patent family                                                                                                                                                                                                    |
| "O" | document referring to an oral disclosure, use, exhibition or other means                                                                                            |     |                                                                                                                                                                                                                                              |
| "P" | document published prior to the international filing date but later than the priority date claimed                                                                  |     |                                                                                                                                                                                                                                              |

Date of the actual completion of the international search

26 SEPTEMBER 1998

Date of mailing of the international search report

28 OCT 1998

Name and mailing address of the ISA/US  
Commissioner of Patents and Trademarks  
Box PCT  
Washington, D.C. 20231

Facsimile No. (703) 305-3230

Authorized officer

David Y. Eng



Telephone No. (703) 605-9691

**INTERNATIONAL SEARCH REPORT**

International application No.  
PCT/US98/13823

**Box I Observations where certain claims were found unsearchable (Continuation of item 1 of first sheet)**

This international report has not been established in respect of certain claims under Article 17(2)(a) for the following reasons:

1.  Claims Nos.: because they relate to subject matter not required to be searched by this Authority, namely:
  
2.  Claims Nos.: because they relate to parts of the international application that do not comply with the prescribed requirements to such an extent that no meaningful international search can be carried out, specifically:
  
3.  Claims Nos.: because they are dependent claims and are not drafted in accordance with the second and third sentences of Rule 6.4(a).

**Box II Observations where unity of invention is lacking (Continuation of item 2 of first sheet)**

This International Searching Authority found multiple inventions in this international application, as follows:

Please See Extra Sheet.

1.  As all required additional search fees were timely paid by the applicant, this international search report covers all searchable claims.
2.  As all searchable claims could be searched without effort justifying an additional fee, this Authority did not invite payment of any additional fee.
3.  As only some of the required additional search fees were timely paid by the applicant, this international search report covers only those claims for which fees were paid, specifically claims Nos.:
  
4.  No required additional search fees were timely paid by the applicant. Consequently, this international search report is restricted to the invention first mentioned in the claims; it is covered by claims Nos.: 1, 25 and 30

**Remark on Protest**  

The additional search fees were accompanied by the applicant's protest.  
No protest accompanied the payment of additional search fees.

**INTERNATIONAL SEARCH REPORT**

International application No.  
PCT/US98/13823

**BOX II. OBSERVATIONS WHERE UNITY OF INVENTION WAS LACKING**

This ISA found multiple inventions as follows:

This application contains the following inventions or groups of inventions which are not so linked as to form a single inventive concept under PCT Rule 13.1. In order for all inventions to be searched, the appropriate additional search fees must be paid.

Group I, claim(s) 1, 25 and 30, drawn to a method for computing logical operations within a processor.

Group II, claim(s) 2-7, drawn to a method for compiling source code.

Group III, claim(s) 8-13, 26-26 and 31-32, drawn to a method for converting linear data into logarithmic data.

Group IV, claims 14-21, 28 and 33, drawn to a method for skipping an instruction.

Group V, claims 22-24, 29 and 34, drawn to a method for calculating a linear interpolation between two values.

The inventions listed as Groups I-V do not relate to a single inventive concept under PCT Rule 13.1 because, under PCT Rule 13.2, they lack the same or corresponding special technical features for the following reasons: Invention I-V are related as subcombinations disclosed as usable together in a single combination. The subcombinations are distinct from each other if they are shown to be separately usable. In the instant case, inventions I-V have separate utility because each of the methods are independent from the others and each of the methods can be used separately in different programs.



INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT)

(54) Title: PROCESSOR WITH INSTRUCTION SET FOR AUDIO EFFECTS



**(57) Abstract**

An instruction set for control of an audio signal processor (200) that allows for a high degree of flexibility in generating desired sound effects. The instruction set serves as a multi-functional instruction base upon which other specialized sound effects can be constructed.

***FOR THE PURPOSES OF INFORMATION ONLY***

Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT.

|    |                          |    |                                       |    |                                           |    |                          |
|----|--------------------------|----|---------------------------------------|----|-------------------------------------------|----|--------------------------|
| AL | Albania                  | ES | Spain                                 | LS | Lesotho                                   | SI | Slovenia                 |
| AM | Armenia                  | FI | Finland                               | LT | Lithuania                                 | SK | Slovakia                 |
| AT | Austria                  | FR | France                                | LU | Luxembourg                                | SN | Senegal                  |
| AU | Australia                | GA | Gabon                                 | LV | Latvia                                    | SZ | Swaziland                |
| AZ | Azerbaijan               | GB | United Kingdom                        | MC | Monaco                                    | TD | Chad                     |
| BA | Bosnia and Herzegovina   | GE | Georgia                               | MD | Republic of Moldova                       | TG | Togo                     |
| BB | Barbados                 | GH | Ghana                                 | MG | Madagascar                                | TJ | Tajikistan               |
| BE | Belgium                  | GN | Guinea                                | MK | The former Yugoslav Republic of Macedonia | TM | Turkmenistan             |
| BF | Burkina Faso             | GR | Greece                                | ML | Mali                                      | TR | Turkey                   |
| BG | Bulgaria                 | HU | Hungary                               | MN | Mongolia                                  | TT | Trinidad and Tobago      |
| BJ | Benin                    | IE | Ireland                               | MR | Mauritania                                | UA | Ukraine                  |
| BR | Brazil                   | IL | Israel                                | MW | Malawi                                    | UG | Uganda                   |
| BY | Belarus                  | IS | Iceland                               | MX | Mexico                                    | US | United States of America |
| CA | Canada                   | IT | Italy                                 | NE | Niger                                     | UZ | Uzbekistan               |
| CF | Central African Republic | JP | Japan                                 | NL | Netherlands                               | VN | Viet Nam                 |
| CG | Congo                    | KE | Kenya                                 | NO | Norway                                    | YU | Yugoslavia               |
| CH | Switzerland              | KG | Kyrgyzstan                            | NZ | New Zealand                               | ZW | Zimbabwe                 |
| CI | Côte d'Ivoire            | KP | Democratic People's Republic of Korea | PL | Poland                                    |    |                          |
| CM | Cameroon                 | KR | Republic of Korea                     | PT | Portugal                                  |    |                          |
| CN | China                    | KZ | Kazakhstan                            | RO | Romania                                   |    |                          |
| CU | Cuba                     | LC | Saint Lucia                           | RU | Russian Federation                        |    |                          |
| CZ | Czech Republic           | LI | Liechtenstein                         | SD | Sudan                                     |    |                          |
| DE | Germany                  | LK | Sri Lanka                             | SE | Sweden                                    |    |                          |
| DK | Denmark                  | LR | Liberia                               | SG | Singapore                                 |    |                          |

REVISED  
VERSION

INTERNATIONAL SEARCH REPORT

International application No.

PCT/US98/13823

**A. CLASSIFICATION OF SUBJECT MATTER**

IPC(6) :G06F 09/305

US CL :395/564

According to International Patent Classification (IPC) or to both national classification and IPC

**B. FIELDS SEARCHED**

Minimum documentation searched (classification system followed by classification symbols)

U.S. : 395/564

Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched

Electronic data base consulted during the international search (name of data base and, where practicable, search terms used)

APS

search terms: logical operation, instruction, operand, operand address, xor, single cycle.

**C. DOCUMENTS CONSIDERED TO BE RELEVANT**

| Category* | Citation of document, with indication, where appropriate, of the relevant passages | Relevant to claim No. |
|-----------|------------------------------------------------------------------------------------|-----------------------|
| Y         | US 4,131,940 A (Moyer) 26 December 1978, col. 9, lines 47-68.                      | 1, 25, 30             |
| Y         | US, 4,785,393 A (Chu et al) 15 November 1988, col. 5, lines 5-31.                  | 1, 25 , 30            |

Further documents are listed in the continuation of Box C.  See patent family annex.

- \* Special categories of cited documents:
- \*T\* later document published after the international filing date or priority date and not in conflict with the application but cited to understand the principle or theory underlying the invention
- \*A\* document defining the general state of the art which is not considered to be of particular relevance
- \*E\* earlier document published on or after the international filing date
- \*L\* document of particular relevance; the claimed invention cannot be considered novel or cannot be considered to involve an inventive step when the document is taken alone
- \*O\* document which may throw doubt on priority claim(s) or which is cited to establish the publication date of another citation or other special reason (as specified)
- \*P\* document referring to an oral disclosure, use, exhibition or other means
- \*Y\* document of particular relevance; the claimed invention cannot be considered to involve an inventive step when the document is combined with one or more other such documents, such combination being obvious to a person skilled in the art
- \*&\* document published prior to the international filing date but later than the priority date claimed
- \* document member of the same patent family

Date of the actual completion of the international search

26 SEPTEMBER 1998

Date of mailing of the international search report

10 FEB 1999

Name and mailing address of the ISA/US  
Commissioner of Patents and Trademarks  
Box PCT  
Washington, D.C. 20231

Facsimile No. (703) 305-3230

Authorized officer

David Y. Eng

Telephone No. (703) 305-9691

*Joni Hill*

# INTERNATIONAL SEARCH REPORT

International application No.

PCT/US98/13823

## Box I Observations where certain claims were found unsearchable (Continuation of item 1 of first sheet)

This international report has not been established in respect of certain claims under Article 17(2)(a) for the following reasons:

1.  Claims Nos.: because they relate to subject matter not required to be searched by this Authority, namely:
  
2.  Claims Nos.: because they relate to parts of the international application that do not comply with the prescribed requirements to such an extent that no meaningful international search can be carried out, specifically:
  
3.  Claims Nos.: because they are dependent claims and are not drafted in accordance with the second and third sentences of Rule 6.4(a).

## Box II Observations where unity of invention is lacking (Continuation of item 2 of first sheet)

This International Searching Authority found multiple inventions in this international application, as follows:

Please See Extra Sheet.

1.  As all required additional search fees were timely paid by the applicant, this international search report covers all searchable claims.
2.  As all searchable claims could be searched without effort justifying an additional fee, this Authority did not invite payment of any additional fee.
3.  As only some of the required additional search fees were timely paid by the applicant, this international search report covers only those claims for which fees were paid, specifically claims Nos.:
  
4.  No required additional search fees were timely paid by the applicant. Consequently, this international search report is restricted to the invention first mentioned in the claims; it is covered by claims Nos.: 1, 25 and 30

### Remark on Protest



The additional search fees were accompanied by the applicant's protest.



No protest accompanied the payment of additional search fees.

**INTERNATIONAL SEARCH REPORT**

International application No.

PCT/US98/13823

**BOX II. OBSERVATIONS WHERE UNITY OF INVENTION WAS LACKING**

This ISA found multiple inventions as follows:

This application contains the following inventions or groups of inventions which are not so linked as to form a single inventive concept under PCT Rule 13.1. In order for all inventions to be searched, the appropriate additional search fees must be paid.

Group I, claim(s)1, 25 and 30, drawn to a method for computing logical operations within a processor.

Group II, claim(s) 2-7, drawn to a method for compiling source code.

Group III, claim(s) 8-13, 26-26 and 31-32, drawn to a method for converting linear data into logarithmic data.

Group IV, claims 14-21, 28 and 33, drawn to a method for skipping an instruction.

Group V, claims 22-24, 29 and 34, drawn to a method for calculating a linear interpolation between two values.

The inventions listed as Groups I-V do not relate to a single inventive concept under PCT Rule 13.1 because, under PCT Rule 13.2, they lack the same or corresponding special technical features for the following reasons: Invention I-V are related as subcombinations disclosed as usable together in a single combination. The subcombinations are distinct from each other if they are shown to be separately usable. In the instant case, inventions I-V have separate utility because each of the methods are independent from the others and each of the methods can be used separately in different programs.